

HIMPP MIPI

# 使用指南

文档版本 00B03

发布日期 2016-09-22

### 版权所有 © 深圳市海思半导体有限公司 2016。保留一切权利。

非经本公司书面许可,任何单位和个人不得擅自摘抄、复制本文档内容的部分或全部,并不得以任 何形式传播。

# 商标声明

(上) 、 **HISILICON** 、 海思和其他海思商标均为深圳市海思半导体有限公司的商标。

本文档提及的其他所有商标或注册商标,由各自的所有人拥有。

#### 注意

您购买的产品、服务或特性等应受海思公司商业合同和条款的约束,本文档中描述的全部或部分产 品、服务或特性可能不在您的购买或使用范围之内。除非合同另有约定,海思公司对本文档内容不 做任何明示或默示的声明或保证。

由于产品版本升级或其他原因,本文档内容会不定期进行更新。除非另有约定,本文档仅作为使用 指导,本文档中的所有陈述、信息和建议不构成任何明示或暗示的担保。

# 深圳市海思半导体有限公司

地址: 深圳市龙岗区坂田华为基地华为电气生产中心 邮编: 518129

网址: http://www.hisilicon.com

客户服务电话: +86-755-28788858

+86-755-28357515 客户服务传真:

客户服务邮箱: support@hisilicon.com



# 前言

# 产品版本

与本文档相对应的产品版本如下。

| 产品名称    | 产品版本 |
|---------|------|
| Hi3516A | V100 |
| Hi3516D | V100 |
| Hi3518E | V200 |
| Hi3518E | V201 |
| Hi3516C | V200 |
| Hi3519  | V100 |
| Hi3519  | V101 |
| Hi3516C | V300 |
| Hi3559  | V100 |

# □ 说明

- 未有特殊说明, Hi3516D 与 Hi3516A 一致。
- 未有特殊说明, Hi3518EV201、Hi3516CV200 和 Hi3518EV200 一致。
- 未有特殊说明, Hi3559V100 和 Hi3519V101 一致。

# 读者对象

本文档(本指南)主要适用于以下工程师:

- 技术支持工程师
- 软件开发工程师



# 符号约定

在本文中可能出现下列标志,它们所代表的含义如下。

| 符号   | 说明                                             |
|------|------------------------------------------------|
| ⚠ 危险 | 表示有高度潜在危险,如果不能避免,会导致人员死亡或严重伤害。                 |
| 警告   | 表示有中度或低度潜在危险,如果不能避免,可能导致人员轻微或中等伤害。             |
| 注意   | 表示有潜在风险,如果忽视这些文本,可能导致设备损坏、数据丢失、设备性能降低或不可预知的结果。 |
| ◎ 窍门 | 表示能帮助您解决某个问题或节省您的时间。                           |
| □ 说明 | 表示是正文的附加信息,是对正文的强调和补充。                         |

# 修订记录

修订记录累积了每次文档更新的说明。最新版本的文档包含以前所有文档版本的更新内容。

# 文档版本 00B03(2016-09-22)

第3次临时版本发布。

新增 Hi3559V100 相关内容。

# 文档版本 00B02(2016-07-12)

第2次临时版本发布。

新增 Hi3516CV300 相关内容。

1.4 小节,HI\_MIPI\_SET\_DEV\_ATTR 内容涉及修改。新增 API 参考 HI\_MIPI\_RESET\_SENSOR、HI\_MIPI\_UNRESET\_SENSOR、HI\_MIPI\_RESET\_MIPI 和 HI\_MIPI\_UNRESET\_MIPI。

1.5 小节,新增数据类型 COMBO\_DEV、HI\_MIPI\_IOC\_MAGIC、phy\_cmv\_e 和 phy\_cmv\_t。

# 文档版本 00B01 (2016-06-20)

第1次临时版本发布。



# 目录

| 前 言                            | i    |
|--------------------------------|------|
| ···                            |      |
| 1.1 概述                         | 1-1  |
| 1.2 重要概念                       |      |
| 1.3 功能描述                       | 1-3  |
| 1.4 API 参考                     | 1-3  |
| 1.5 数据类型                       | 1-10 |
| 1.6 PROC 信息                    |      |
| 1.7 FAQ                        |      |
| 1.7.2 LVDS mode sync code 如何配置 |      |
| 1.7.3 MIPI 频率说明                | 1-48 |
| 1.7.4 Sensor 复位                | 1-48 |



# 【 HiMPP MIPI 使用指南

# 1.1 概述

MIPI Rx 通过低电压差分信号接收原始视频数据,将接收到的串行差分信号(serial differential signal)转化为 DC(Digital Camera)时序后传递给下一级模块 ViCAP(Video Capture)

MIPI Rx 支持 MIPI D-PHY、LVDS(Low-Voltage Differential Signal)、HiSPi(High-Speed Serial Pixel Interface)等串行视频信号输入,同时兼容 DC 视频接口。

# 1.2 重要概念

MIPI

MIPI 的全称是 Mobile Industry Processor Interface(移动行业处理器接口),本文描述的 MIPI 接口特指物理层使用 D-PHY 传输规范,协议层使用 CSI-2 的通信接口。

LVDS

LVDS 的全称是 Low Voltage differential Signaling(低压差分信号),通过同步码区分消隐区和有效数据。

Lane

用于连接发送端和接收端的一对高速差分线,即可以是时钟 Lane,也可以是数据 Lane。

Link

发送端和接收端之间的时钟 Lane 和至少一个数据 Lane 组成一个 Link。

● 同步码

MIPI 接口使用 CSI-2 里面的短包进行同步,LVDS 使用同步码区分有效数据和消 隐区。LVDS 有两种同步方式:

- 使用 SOF/EOF 表示帧起始和结束,使用 SOL/EOL 表示行的起始和结束。同步方式如图 1-1 所示。



图1-1 SOF/EOF/SOL/EOL 同步方式

| V.BLK |     |                 |     |       |
|-------|-----|-----------------|-----|-------|
| H.BLK | SOF | Effective Pixel |     | H.BLK |
| H.BLK |     | Effective Pixel |     | H.BLK |
| H.BLK |     | Effective Pixel | ] [ | H.BLK |
| H.BLK |     | Effective Pixel |     | H.BLK |
| ı     |     |                 |     | :     |
| H.BLK |     | Effective Pixel | EOL | H.BLK |
| H.BLK | SOL | Effective Pixel |     | H.BLK |
| H.BLK |     | Effective Pixel |     | H.BLK |
| H.BLK |     | Effective Pixel | ] [ | H.BLK |
| H.BLK |     | Effective Pixel |     | H.BLK |
| H.BLK |     | Effective Pixel |     | H.BLK |
| H.BLK |     | Effective Pixel | EOF | H.BLK |
| V.BLK |     |                 |     |       |

- 使用 SAV(invalid) EAV(invalid)表示消隐区的无效数据开始和结束,使用 SAV(valid) EAV(valid)表示有效像素数据的开始和结束。

每个同步码由 4 个字段组成,每个字段的位宽与像素数据位宽保持一致。前 3 个字段为固定基准码字,第 4 个字段由 sensor 厂家确定。

由于不同的 sensor 可能会有不同的同步码,所以需要根据 sensor 配置同步码。同步方式如图 1-2 所示。

图1-2 SAV/EAV 同步方式

| H.BLK | SAV             | V.BLK                  | EAV      | H.BLK |
|-------|-----------------|------------------------|----------|-------|
| H.BLK | (Invalid        | V.BLK                  | (Invalid | H.BLK |
| H.BLK | line)           | V.BLK                  | `line)   | H.BLK |
| H.BLK |                 | H.OB / effective pixel |          | H.BLK |
| H.BLK |                 | H.OB / effective pixel |          | H.BLK |
| H.BLK |                 | H.OB / effective pixel |          | H.BLK |
| :     |                 | •                      |          | -     |
| H.BLK | SAV             | H.OB / effective pixel | EAV      | H.BLK |
| H.BLK | (Valid<br>line) | H.OB / effective pixel | (Valid   | H.BLK |
| H.BLK | iii ie)         | H.OB / effective pixel | line)    | H.BLK |
| H.BLK |                 | H.OB / effective pixel |          | H.BLK |
| H.BLK |                 | H.OB / effective pixel |          | H.BLK |
| H.BLK |                 | H.OB / effective pixel |          | H.BLK |
| H.BLK |                 | V.BLK                  |          | H.BLK |
| :     | SAV             | i.                     | EAV      | :     |
| H.BLK | (Invalid        | V.BLK                  | (Invalid | H.BLK |
| H.BLK | line)           | V.BLK                  | line)    | H.BLK |
| H.BLK |                 | V.BLK                  |          | H.BLK |

• DOL



DOL 的全称是 Digital Overlap, 指 SONY 的 WDR 功能。

# 1.3 功能描述

MIPI Rx 是一个支持多种差分视频输入接口的采集单元,通过 combo-PHY 接收 MIPI/LVDS/sub-LVDS/HiSPi/DC 接口的数据,通过不同的功能模式配置,MIPI Rx 可以 支持多种速度和分辨率的数据传输需求,支持多种外部输入设备。

表1-1 最大支持 lane 的个数

| 芯片类型                    | 定义                                                      |  |
|-------------------------|---------------------------------------------------------|--|
| Hi3516A                 | MIPI Rx 最大支持 1Link/4Lane MIPI 输入或 2Link/8Lane LVDS 输入。  |  |
| Hi3518EV200/Hi3516CV300 | MIPI Rx 最大支持 1Link/4Lane MIPI 输入或 1Link/4Lane LVDS 输入。  |  |
| Hi3519V100/Hi3519V101   | MIPI Rx 最大支持 2Link/8Lane MIPI 输入或 3Link/12Lane LVDS 输入。 |  |

以上输入管脚可复用为单端 DC/BT.1120 通道输入,从而可以用更少的芯片管脚提供更好的兼容性。

# 1.4 API 参考

MIPI Rx 提供对接 sensor 时序的功能。提供 ioctl 接口,可用的命令如下:

- HI MIPI SET DEV ATTR: 设置 MIPI 设备属性。
- HI\_MIPI\_SET\_PHY\_CMVMODE:设置共模电压模式。
- HI MIPI SET CROP: 设置 MIPI CROP 属性。
- HI MIPI RESET SENSOR: 复位 sensor。
- HI\_MIPI\_UNRESET\_SENSOR: 撤销复位 sensor。
- HI\_MIPI\_RESET\_MIPI: 复位 MIPI Rx。
- HI\_MIPI\_UNRESET\_MIPI: 撤销复位 MIPI Rx。

# HI\_MIPI\_SET\_DEV\_ATTR

#### 【描述】

设置 MIPI Rx 设备属性。

#### 【定义】

#define HI\_MIPI\_SET\_DEV\_ATTR

\_IOW(HI\_MIPI\_IOC\_MAGIC, 0x01,

combo\_dev\_attr\_t)



#### 【参数】

combo\_dev\_attr\_t 类型的指针

#### 【返回值】

| 返回值 | 描述           |
|-----|--------------|
| 0   | 成功。          |
| -1  | 失败,并设置 errno |

#### 【芯片差异】

| 芯片类型        | 内部流程             |  |
|-------------|------------------|--|
| Hi3516A     | 接口内部包含如下流程:      |  |
|             | 1. 复位 sensor     |  |
|             | 2. 复位 MIPI Rx    |  |
| Hi3518EV200 | 3. 撤销复位 MIPI Rx  |  |
|             | 4. 配置 MIPI RX 参数 |  |
|             | 5. 撤销复位 sensor   |  |
| Hi3519V100  | 配置 MIPI Rx 参数。   |  |
| Hi3519V101  |                  |  |
| Hi3516CV300 |                  |  |

#### 【需求】

头文件: hi\_mipi.h

# 【注意】

Hi3519V100/HI3519V101/Hi3516CV300:

- 除了配置 HI MIPI SET DEV ATTR 之外,还需要配置以下接口。
- 复位 sensor、撤销复位 sensor、复位 MIPI Rx 和撤销复位 MIPI Rx 的操作被剥离为 独立的接口,对应的接口如下:
  - 复位 sensor: HI\_MIPI\_RESET\_SENSOR
  - 撤销复位 sensor: HI\_MIPI\_UNRESET\_SENSOR
  - 复位 MIPI Rx: HI\_MIPI\_RESET\_MIPI
  - 撤销复位 MIPI Rx: HI\_MIPI\_UNRESET\_MIPI
- 推荐的配置流程如下:
  - 1. 复位 MIPI Rx
  - 2. 复位 sensor



- 3. 配置 MIPI Rx 设备属性
- 4. 撤销复位 MIPI Rx
- 5. 撤销复位 sensor

# 【相关数据类型及接口】

- HI MIPI RESET SENSOR
- HI\_MIPI\_UNRESET\_SENSOR
- HI\_MIPI\_RESET\_MIPI
- HI\_MIPI\_UNRESET\_MIPI

# HI\_MIPI\_SET\_PHY\_CMVMODE

#### 【描述】

设置共模电压模式。

#### 【定义】

#### 【参数】

phy\_cmv\_t 类型的指针。

#### 【返回值】

| 返回值 | 描述           |
|-----|--------------|
| 0   | 成功。          |
| -1  | 失败,并设置 errno |

#### 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |
| Hi3519V100  | 支持   |
| Hi3519V101  | 支持   |
| Hi3516CV300 | 支持   |

#### 【需求】

头文件: hi\_mipi.h



#### 【注意】

无。

# HI\_MIPI\_SET\_CROP

#### 【描述】

设置 MIPI CROP 配置。

# 【定义】

#define HI\_MIPI\_SET\_CROP

\_IOW(HI\_MIPI\_IOC\_MAGIC, 0x05, img\_rect\_t)

#### 【参数】

img\_rect\_t 类型的指针。

#### 【返回值】

| 返回值 | 描述           |
|-----|--------------|
| 0   | 成功。          |
| -1  | 失败,并设置 errno |

#### 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |
| Hi3519V100  | 支持   |
| Hi3519V101  | 不支持  |
| Hi3516CV300 | 不支持  |

#### 【需求】

头文件: hi mipi.h

#### 【注意】

- 在 HI\_MIPI\_SET\_DEV\_ATTR 接口后调用此接口, Crop 才会生效。 (HI\_MIPI\_SET\_DEV\_ATTR 默认关闭 CROP 功能)。
- 需要根据 sensor 实际输出宽高进行 crop 配置,(x+width, y+height)不能超过实际图像分辨率。
- Crop 的图像宽度必须是有效 lane 个数的整数倍。



# HI\_MIPI\_RESET\_SENSOR

#### 【描述】

复位 sensor。

#### 【定义】

#define HI\_MIPI\_RESET\_SENSOR \_IOW(HI\_MIPI\_IOC\_MAGIC, 0x05, COMBO\_DEV)

#### 【参数】

COMBO DEV 设备号。

#### 【返回值】

| 返回值 | 描述           |  |
|-----|--------------|--|
| 0   | 成功。          |  |
| -1  | 失败,并设置 errno |  |

# 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |
| Hi3519V100  | 支持   |
| Hi3519V101  | 支持   |
| Hi3516CV300 | 支持   |

#### 【需求】

头文件: hi\_mipi.h

【注意】

无。

# HI\_MIPI\_UNRESET\_SENSOR

# 【描述】

撤销复位 sensor。

#### 【定义】



# 【参数】

COMBO\_DEV 设备号。

# 【返回值】

| 返回值 | 描述           |  |
|-----|--------------|--|
| 0   | 成功。          |  |
| -1  | 失败,并设置 errno |  |

# 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |
| Hi3519V100  | 支持   |
| Hi3519V101  | 支持   |
| Hi3516CV300 | 支持   |

# 【需求】

头文件: hi\_mipi.h

# 【注意】

无。

# HI\_MIPI\_RESET\_MIPI

# 【描述】

复位 MIPI\_Rx。

# 【定义】

#define HI\_MIPI\_RESET\_MIPI \_\_IOW(HI\_MIPI\_IOC\_MAGIC, 0x07, COMBO\_DEV)

# 【参数】

COMBO\_DEV 设备号。

# 【返回值】

| 返回值 | 描述           |  |
|-----|--------------|--|
| 0   | 成功。          |  |
| -1  | 失败,并设置 errno |  |



# 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |
| Hi3519V100  | 支持   |
| Hi3519V101  | 支持   |
| Hi3516CV300 | 支持   |

# 【需求】

头文件: hi\_mipi.h

# 【注意】

无。

# HI\_MIPI\_UNRESET\_MIPI

# 【描述】

撤销复位 MIPI\_Rx。

# 【定义】

#define HI\_MIPI\_UNRESET\_MIPI \_IOW(HI\_MIPI\_IOC\_MAGIC, 0x08, COMBO\_DEV)

# 【参数】

COMBO\_DEV 设备号。

# 【返回值】

| 返回值 | 描述           |
|-----|--------------|
| 0   | 成功。          |
| -1  | 失败,并设置 errno |

# 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |



| Hi3519V100  | 支持 |
|-------------|----|
| Hi3519V101  | 支持 |
| Hi3516CV300 | 支持 |

#### 【需求】

头文件: hi\_mipi.h

#### 【注意】

无。

# 1.5 数据类型

MIPI Rx 相关数据类型定义如下:

- HI MIPI IOC MAGIC: MIPI Rx ioctl 命令的幻数。
- COMBO DEV: MIPI Rx 设备类型。
- COMBO\_MAX\_LINK\_NUM:设备最大的支持的 Link 数量。
- LANE NUM PER LINK:每个 Link 最多支持的 Lane。
- COMBO\_MAX\_LANE\_NUM:设备最大支持的 Lane 数量。
- MIPI LANE NUM: MIPI 接口支持的 Lane 数量。
- LVDS LANE NUM: LVDS/HiSPi 接口支持的 Lane 数量。
- COMBO MAX DEV NUM: MIPI Rx 设备的数量。
- WDR VC NUM: 定义最多支持的 Virtual Chnnael 数量。
- SYNC CODE NUM:每个 Virtual Channel 的同步码数量。
- input\_mode\_t: MIPI Rx 输入接口类型。
- phy clk share e: PHY1 与 PHY2 是否与 PHY0 共用时钟。
- raw data type e: 传输的 raw 数据比特数。
- mipi wdr mode e: MIPI WDR 模式。
- mipi\_dev\_attr\_t: MIPI 设备属性。
- wdr\_mode\_e: LVDS WDR 模式。
- lvds sync mode e: LVDS 同步方式。
- lvds bit endian: 比特位大小端模式。
- lvds\_vsync\_type\_e: LVDS VSYNC 类型。
- lvds vsync type t: LVDS VSYNC 参数。
- lvds\_fid\_type\_e: Frame identification Id 类型。
- lvds fid type t: Frame indentification Id 配置信息。
- lvds\_dev\_attr\_t: LVDS/SubLVDS/HiSPi 设备属性。



- phy\_cmv\_e: PHY 共模电压模式。
- phy cmv t: PHY 共模电压配置信息
- combo\_dev\_attr\_t: combo 设备属性。
- img\_rect\_t: crop 属性。
- img\_size\_t: 图像宽高属性。

# HI\_MIPI\_IOC\_MAGIC

#### 【说明】

MIPI Rx ioctl 命令的幻数。

#### 【定义】

#define HI\_MIPI\_IOC\_MAGIC 'm'

#### 【成员】

无

【芯片差异】

无。

【注意事项】

无。

【相关数据类型及接口】

无

# COMBO\_DEV

#### 【说明】

MIPI Rx 设备类型。

#### 【定义】

typedef unsigned int COMBO\_DEV;

#### 【芯片差异】

无。

【注意事项】

无。

#### 【相关数据类型及接口】

- combo\_dev\_attr\_t
- HI\_MIPI\_SET\_DEV\_ATTR
- HI\_MIPI\_RESET\_SENSOR



- HI\_MIPI\_UNRESET\_SENSOR
- HI MIPI RESET MIPI
- HI\_MIPI\_UNRESET\_MIPI

# COMBO\_MAX\_LINK\_NUM

# 【说明】

设备最大的支持的 Link 数量。

# 【芯片差异】

| 芯片类型        | 定义                                                               |
|-------------|------------------------------------------------------------------|
| Hi3516A     | #define COMBO_MAX_LINK_NUM 2                                     |
| Hi3518EV200 | #define COMBO_MAX_LINK_NUM 2<br>(只有一个 Link,为了兼容 Hi3516A 所以定义为 2) |
| Hi3519V100  | #define COMBO_MAX_LINK_NUM 3                                     |
| Hi3519V101  | #define COMBO_MAX_LINK_NUM 3                                     |
| Hi3516CV300 | #define COMBO_MAX_LINK_NUM 1                                     |

#### 【注意事项】

无。

【相关数据类型及接口】

无。

# LANE\_NUM\_PER\_LINK

#### 【说明】

每个 Link 最多支持的 Lane。

#### 【定义】

#define LANE\_NUM\_PER\_LINK 4

【芯片差异】

无。

【注意事项】

无。

【相关数据类型及接口】

无。



# COMBO\_MAX\_LANE\_NUM

# 【说明】

设备最大支持的 Lane 数量。

#### 【芯片差异】

| 芯片类型        | 定义                                                                 |
|-------------|--------------------------------------------------------------------|
| Hi3516A     | #define COMBO_MAX_LANE_NUM 8                                       |
| Hi3518EV200 | #define COMBO_MAX_LANE_NUM 8<br>(只有 4 个 Lane,为了兼容 Hi3516A 所以定义为 8) |
| Hi3519V100  | #define COMBO_MAX_LANE_NUM 12                                      |
| Hi3519V101  | #define COMBO_MAX_LANE_NUM 12                                      |
| Hi3516CV300 | #define COMBO_MAX_LANE_NUM 4                                       |

# 【注意事项】

无。

【相关数据类型及接口】

无。

# MIPI\_LANE\_NUM

# 【说明】

MIPI 接口支持的 Lane 数量。

# 【芯片差异】

| 芯片类型        | 定义                    |                         |
|-------------|-----------------------|-------------------------|
| Hi3516A     | #define MIPI_LANE_NUM | COMBO_MAX_LANE_NUM      |
| Hi3518EV200 | #define MIPI_LANE_NUM | COMBO_MAX_LANE_NUM      |
| Hi3519V100  | #define MIPI_LANE_NUM | (LANE_NUM_PER_LINK * 2) |
| Hi3519V101  | #define MIPI_LANE_NUM | (LANE_NUM_PER_LINK * 2) |
| Hi3516CV300 | #define MIPI_LANE_NUM | (LANE_NUM_PER_LINK * 1) |

# 【注意事项】

无。

【相关数据类型及接口】

无。



# LVDS\_LANE\_NUM

### 【说明】

LVDS/HiSPi 接口支持的 Lane 数量。

【定义】

#define LVDS\_LANE\_NUM

COMBO\_MAX\_LANE\_NUM

【芯片差异】

无。

【注意事项】

无。

【相关数据类型及接口】

无。

# COMBO\_MAX\_DEV\_NUM

# 【说明】

MIPI Rx 设备的数量。

# 【芯片差异】

| 芯片类型        | 定义                        |   |
|-------------|---------------------------|---|
| Hi3516A     | 无                         |   |
| Hi3518EV200 | 无                         |   |
| Hi3519V100  | #define COMBO_MAX_DEV_NUM | 1 |
| Hi3519V101  | #define COMBO_MAX_DEV_NUM | 2 |
| Hi3516CV300 | #define COMBO_MAX_DEV_NUM | 1 |

# 【注意事项】

无。

【相关数据类型及接口】

无。

# WDR\_VC\_NUM

# 【说明】

定义最多支持的 Virtual Chnnael 数量

【定义】



```
#define WDR_VC_NUM
                                      4
              【芯片差异】
              无。
              【注意事项】
              无。
              【相关数据类型及接口】
              无。
SYNC_CODE_NUM
              【说明】
              每个 Virtual Channel 的同步码数量
              【定义】
              #define SYNC_CODE_NUM
              【芯片差异】
              无
              【注意事项】
              无。
              【相关数据类型及接口】
              无。
input_mode_t
              【说明】
              MIPI Rx 输入接口类型
              【定义】
              Hi3516A/Hi3518EV200
              typedef enum
                 INPUT_MODE_MIPI
                                    = 0 \times 0,
                                                     /* mipi */
                                                      /* SUB_LVDS */
                 INPUT_MODE_SUBLVDS
                                     = 0x1,
                                     = 0x2,
                 INPUT_MODE_LVDS
                                                      /* LVDS */
                 INPUT_MODE_HISPI
                                      = 0x3,
                                                      /* HISPI */
                 INPUT_MODE_CMOS_18V
                                                      /* CMOS 1.8V */
                                     = 0x4
                 INPUT_MODE_CMOS_33V
                                      = 0x5,
                                                      /* CMOS 3.3V */
                 INPUT_MODE_BT1120
                                      = 0x6
                                                      /* CMOS 3.3V */
```

= 0x7,

INPUT\_MODE\_BYPASS

/\* MIPI Bypass \*/



```
INPUT_MODE_BUTT
}input_mode_t;
```

#### Hi3519V100/Hi3519V101

```
typedef enum
{
   INPUT_MODE_MIPI
                       = 0x0,
                                      /* CSI-2 */
   INPUT_MODE_SUBLVDS
                       = 0x1,
                                      /* SUB_LVDS */
                       = 0x2,
                                       /* LVDS */
   INPUT_MODE_LVDS
   INPUT_MODE_HISPI
                       = 0x3,
                                      /* HISPI */
                                      /* CMOS */
   INPUT_MODE_CMOS
                       = 0x4
   INPUT_MODE_BT1120
                                      /* CMOS */
                       = 0x5,
   INPUT_MODE_BYPASS
                                      /* MIPI Bypass */
                       = 0x6,
   INPUT_MODE_BUTT
} input_mode_t;
```

#### Hi3516CV300

```
typedef enum
{
   INPUT_MODE_MIPI
                       = 0x0,
                                       /* CSI-2 */
   INPUT\_MODE\_SUBLVDS = 0x1,
                                       /* SUB_LVDS */
   INPUT_MODE_LVDS
                       = 0x2
                                       /* LVDS */
   INPUT_MODE_HISPI
                        = 0x3,
                                       /* HISPI */
   INPUT_MODE_CMOS
                       = 0x4,
                                       /* CMOS */
   INPUT_MODE_BT1120
                       = 0x5,
                                       /* CMOS */
   INPUT_MODE_BUTT
} input_mode_t;
```

#### 【芯片差异】

| 芯片类型                              | input_mode_t                                                           |
|-----------------------------------|------------------------------------------------------------------------|
| Hi3516A/Hi3518EV200               | CMOS 模式定义为<br>INPUT_MODE_CMOS_18V、<br>INPUT_MODE_CMOS_33V。             |
| Hi3519V100/Hi3519V101/Hi3516CV300 | MIPI Rx 能够识别 1.8V 和 3.3V 的 CMOS,<br>所以 CMOS 模式统一定义为<br>INPUT_MODE_CMOS |

#### 【注意事项】

不支持 INPUT MODE BYPASS。



# 【相关数据类型及接口】

无。

# phy\_clk\_share\_e

# 【说明】

PHY1 与 PHY2 是否与 PHY0 共用时钟

# 【定义】

# 【成员】

| 成员名称               | 描述                     |
|--------------------|------------------------|
| PHY_CLK_SHARE_NONE | PHY1 和 PHY2 使用独立的时钟    |
| PHY_CLK_SHARE_PHY0 | PHY1 和 PHY2 共用 PHY0 时钟 |

# 【芯片差异】

| 芯片类型        | 是否支持 PHY 共用时钟 |
|-------------|---------------|
| Hi3516A     | 不支持           |
| Hi3518EV200 | 不支持           |
| Hi3519V100  | 支持            |
| Hi3519V101  | 支持            |
| Hi3516CV300 | 不支持           |

# 【注意事项】

无。

【相关数据类型及接口】

无。



# raw\_data\_type\_e

### 【说明】

传输的 raw 数据比特数

#### 【定义】

#### Hi3516A/Hi3518EV200

```
typedef enum
{
    RAW_DATA_8BIT = 1,
    RAW_DATA_10BIT,
    RAW_DATA_12BIT,
    RAW_DATA_14BIT,
    RAW_DATA_BUTT
}raw_data_type_e;
```

#### Hi3519V100/Hi3519V101/Hi3516CV300

```
typedef enum
{
    RAW_DATA_8BIT = 0,
    RAW_DATA_10BIT,
    RAW_DATA_12BIT,
    RAW_DATA_14BIT,
    RAW_DATA_16BIT,
    RAW_DATA_BUTT
} raw_data_type_e;
```

#### 【芯片差异】

无。

【注意事项】

无。

【相关数据类型及接口】

无。

# mipi\_wdr\_mode\_e

#### 【说明】

MIPI WDR 模式。

#### 【定义】

```
typedef enum
{
    HI_MIPI_WDR_MODE_NONE = 0x0,
```



# 【成员】

| 成员名称                  | 描述                                                 |
|-----------------------|----------------------------------------------------|
| HI_MIPI_WDR_MODE_NONE | 线性模式                                               |
| HI_MIPI_WDR_MODE_VC   | 使用 Packet header 中的 Virtual Channel 区分长短曝光帧        |
| HI_MIPI_WDR_MODE_DT   | 使用 Packet header 中的自定义 Data type 区分长短曝光帧           |
| HI_MIPI_WDR_MODE_DOL  | 表示 DOL 模式 WDR,使用 Packet header 之后的一个 pixel 识别长短曝光帧 |

# 【芯片差异】

| 芯片类型        | 是否支持 mipi_wdr_mode_e |
|-------------|----------------------|
| Hi3516A     | 不支持                  |
| Hi3518EV200 | 不支持                  |
| Hi3519V100  | 支持                   |
| Hi3519V101  | 支持                   |
| Hi3516CV300 | 支持                   |

#### 【注意事项】

无

【相关数据类型及接口】

无。

# mipi\_dev\_attr\_t

# 【说明】

mipi 设备属性。

# 【定义】

### Hi3516A/Hi3518EV200:



#### Hi3519V100/Hi3519V101/Hi3516CV300:

# 【成员】

| 成员名称          | 描述                                                                         |
|---------------|----------------------------------------------------------------------------|
| raw_data_type | 传输的 raw data 比特数                                                           |
| lane_id       | 发送端(sensor)和接收端(MIPI Rx) lane 的对应关系<br>未使用的 lane 设置为-1                     |
| wdr_mode      | MIPI WDR 模式                                                                |
| data_type     | 当 wdr_mode 为 HI_MIPI_WDR_MODE_DT 时,需要设置 data_type,表示不同曝光长度数据对应的 Data Type。 |

# 【芯片差异】

| 芯片类型                              | 支持的 raw_data_type               |
|-----------------------------------|---------------------------------|
| Hi3516A                           | 支持 10bit/12bit/14bit            |
| Hi3518EV200                       | 支持 8bit/10bit/12bit/14bit       |
| Hi3519V100/Hi3519V101/Hi3516CV300 | 支持 8bit/10bit/12bit/14bit/16bit |



| 芯片类型                                  | wdr_mode                                                                    |
|---------------------------------------|-----------------------------------------------------------------------------|
| Hi3516A/Hi3518EV2<br>00               | 不支持设置 wdr_mode,默认使用 Virtual Channel 区分不同曝光长度的数据。                            |
| Hi3519V100/Hi3519<br>V101/Hi3516CV300 | 支持设置 wdr_mode,除了支持 Virtual Channel 模式之外,还支持 DataType WDR 和 Sony DOL 模式 WDR。 |

#### 【注意事项】

无。

#### 【相关数据类型及接口】

- raw data type e
- mipi\_wdr\_mode\_e
- HI\_MIPI\_SET\_DEV\_ATTR

# wdr\_mode\_e

#### 【说明】

LVDS WDR 模式

#### 【定义】

```
typedef enum
{
    HI_WDR_MODE_NONE = 0x0,
    HI_WDR_MODE_2F = 0x1,
    HI_WDR_MODE_3F = 0x2,
    HI_WDR_MODE_4F = 0x3,
    HI_WDR_MODE_DOL_2F = 0x4,
    HI_WDR_MODE_DOL_3F = 0x5,
    HI_WDR_MODE_DOL_4F = 0x6,
    HI_WDR_MODE_BUTT
} wdr_mode_e;
```

# 【成员】

| 成员名称               | 描述              |
|--------------------|-----------------|
| HI_WDR_MODE_NONE   | 线性模式            |
| HI_WDR_MODE_2F     | 2 合一 WDR        |
| HI_WDR_MODE_3F     | 3 合一 WDR        |
| HI_WDR_MODE_4F     | 4 合一 WDR        |
| HI_WDR_MODE_DOL_2F | DOL 模式 2 合一 WDR |



| 成员名称               | 描述              |
|--------------------|-----------------|
| HI_WDR_MODE_DOL_3F | DOL 模式 3 合一 WDR |
| HI_WDR_MODE_DOL_4F | DOL 模式 4 合一 WDR |

# 【芯片差异】

无。

# 【注意事项】

- DOL WDR 模式需要配置为 HI\_WDR\_MODE\_DOL\_2F/ HI\_WDR\_MODE\_DOL\_3F/ HI\_WDR\_MODE\_DOL\_4F。
- Built-in WDR 模式和帧合成 WDR 模式都需要配置为 HI\_WDR\_MODE\_NONE。

# 【相关数据类型及接口】

无。

# lvds\_sync\_mode\_e

# 【说明】

LVDS 同步方式。

# 表1-2 LVDS 同步方式

| sync_mode                                 | 同步方式                                                    |
|-------------------------------------------|---------------------------------------------------------|
| LVDS_SYNC_MODE_SOL/<br>LVDS_SYNC_MODE_SOF | SOF、EOF、SOL、EOL<br>请参考图 1-1                             |
| LVDS_SYNC_MODE_SAV                        | invalid SAV、invalid EAV、valid SAV、valid EAV<br>请参考图 1-2 |

# 【芯片差异】

| 芯片类型                  | 定义                      |  |  |
|-----------------------|-------------------------|--|--|
| Hi3516A/Hi3518EV200   | typedef enum            |  |  |
| 1113310711133102 1200 | {                       |  |  |
|                       | LVDS_SYNC_MODE_SOL = 0, |  |  |
|                       | LVDS_SYNC_MODE_SAV,     |  |  |
|                       | LVDS_SYNC_MODE_BUTT     |  |  |
|                       | } lvds_sync_mode_e;     |  |  |



```
Hi3519V100/Hi3519V101/Hi3516CV300 typedef enum
{
    LVDS_SYNC_MODE_SOF = 0,
    LVDS_SYNC_MODE_SAV,
    LVDS_SYNC_MODE_BUTT
} lvds_sync_mode_e;
```

#### 【注意事项】

LVDS\_SYNC\_MODE\_SOF 与 LVDS\_SYNC\_MODE\_SOL 的含义相同,Hi3519V100 更 名为 LVDS\_SYNC\_MODE\_SOF。

【相关数据类型及接口】

无。

# lvds\_bit\_endian

#### 【说明】

比特位大小端模式

```
【定义】
```

```
typedef enum
{
    LVDS_ENDIAN_LITTLE = 0x0,
    LVDS_ENDIAN_BIG = 0x1,
    LVDS_ENDIAN_BUTT
}lvds_bit_endian;
```

#### 【芯片差异】

无。

【注意事项】

无。

【相关数据类型及接口】

无。

# lvds\_vsync\_type\_e

【说明】

LVDS VSYNC 类型。

# 【定义】

```
typedef enum
{
```



LVDS\_VSYNC\_NORMAL = 0x00,

LVDS\_VSYNC\_SHARE = 0x01,

LVDS\_VSYNC\_HCONNECT = 0x02,

LVDS\_VSYNC\_BUTT

} lvds\_vsync\_type\_e;

# 【成员】

| 成员名称                | 描述                                                                         |
|---------------------|----------------------------------------------------------------------------|
| LVDS_VSYNC_NORMAL   | 长短曝光帧有独立的 SOF-EOF、SOL-EOL 或者 invalid SAV-invalid EAV, valid SAV-valid EAV。 |
| LVDS_VSYNC_SHARE    | 长短曝光帧共用一对 SOF-EOF 标识,短曝光的<br>起始几行用固定值填充。                                   |
| LVDS_VSYNC_HCONNECT | 长短曝光帧共用一对 SAV-EAV 标识,长短曝光帧之间是固定周期的消隐。                                      |

# LVDS\_VSYNC\_SHARE 同步方式:

| SOF | Long Exposure | EOL | Horizontal<br>Blanking | SOL | Padding        | EOL | Horizo<br>ntal<br>Blanki<br>ng |
|-----|---------------|-----|------------------------|-----|----------------|-----|--------------------------------|
| SOL |               |     |                        |     |                |     | 5                              |
|     |               |     |                        |     | Short Exposure |     |                                |
|     | Padding       |     |                        |     |                |     |                                |
|     |               |     |                        |     |                | EOF |                                |
| SOV | V.BLK         | EOV | -                      | SOV | V.BLK          | EOV | -                              |

# LVDS\_VSYNC\_HCONNECT 同步方式:

| SAV | Long Exposure | Horizontal           | V.BLK                   | Horizontal           | V.BLK             | EAV | Horizontal |
|-----|---------------|----------------------|-------------------------|----------------------|-------------------|-----|------------|
|     | frame         | Blanking(fix period) | Short<br>ExposureFrame1 | Blanking(fix period) |                   |     | Blanking   |
|     |               |                      |                         |                      | Short<br>Exposure |     |            |
|     | V.BLK         |                      |                         |                      | Frame2            |     |            |
|     |               |                      | V.BLK                   |                      |                   |     |            |



| VBLK  |  |
|-------|--|
| V.BER |  |

#### 【芯片差异】

| 芯片类型                  | 是否支持 lvds_vsync_type_e |
|-----------------------|------------------------|
| Hi3516A/Hi3518EV200   | 不支持                    |
| Hi3519V100/Hi3519V101 | 支持                     |
| Hi3516CV300           | 支持                     |

#### 【注意事项】

无。

【相关数据类型及接口】

lvds\_vsync\_type\_t

# lvds\_vsync\_type\_t

# 【说明】

LVDS vsync 参数

# 【定义】

```
typedef struct
{
    lvds_vsync_type_e sync_type;

    unsigned short hblank1;
    unsigned short hblank2;
} lvds_vsync_type_t;
```

# 【芯片差异】

| 芯片类型                  | 是否支持 lvds_vsync_type_t |
|-----------------------|------------------------|
| Hi3516A/Hi3518EV200   | 不支持                    |
| Hi3519V100/Hi3519V101 | 支持                     |
| Hi3516CV300           | 支持                     |

# 【注意事项】



当 sync\_type 为 LVDS\_VSYNC\_HCONNECT 时,需要配置 hblank1 和 hblank2,表示 Hconnect 的消隐区长度。

# 【相关数据类型及接口】

lvds vsync type e

# lvds\_fid\_type\_e

#### 【说明】

Frame identification Id 类型

#### 【定义】

#### 【成员】

| 成员名称             | 描述                                                                                               |
|------------------|--------------------------------------------------------------------------------------------------|
| LVDS_FID_NONE    | 不使用 frame identification id。                                                                     |
| LVDS_FID_IN_SAV  | FID 插入在 SAV 第 4 个字段中,DOL 4 个字段的同步码需要将 fid_type 配置为 LVDS_FID_IN_SAV。                              |
| LVDS_FID_IN_DATA | FID 作为 Frame information column 插入在同步码之后的第一个像素之前,DOL 5 个字段的同步码需要将 fid_type 配置为 LVDS_FID_IN_DATA。 |

# 【芯片差异】

| 芯片类型                  | 是否支持 lvds_fid_type_e |
|-----------------------|----------------------|
| Hi3516A/Hi3518EV200   | 不支持                  |
| Hi3519V100/Hi3519V101 | 支持                   |
| Hi3516CV300           | 支持                   |

#### 【注意事项】

无。



# 【相关数据类型及接口】

无。

# lvds\_fid\_type\_t

# 【说明】

Frame indentification Id 配置信息。

# 【定义】

```
typedef struct
{
    lvds_vsync_type_e fid;

    HI_BOOL output_fil;
} lvds_fid_type_t;
```

# 【成员】

| 成员名称       | 描述                                                                                                                                                                                                                                        |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| fid        | LVDS DOL 模式下的 Frame identification Id 类型                                                                                                                                                                                                  |
| output_fil | DOL 模式中的 Frame information line 紧接在 V-Blanking 之后输出,Frame ID 是 Frame information line 中的第一个像素值。 Frame information line 中并不包含有效的视频数据,如果output_fil 设置为 HI_TRUE,Frame information line 会输出到后端设备。如果 output_fil 设置为 HI_FALSE,MIPI Rx 将丢弃这一行数据。 |

# 【芯片差异】

| 芯片类型                  | 是否支持 lvds_fid_type_t |
|-----------------------|----------------------|
| Hi3516A/Hi3518EV200   | 不支持                  |
| Hi3519V100/Hi3519V101 | 支持                   |
| Hi3516CV300           | 支持                   |

# 【注意事项】

无。

【相关数据类型及接口】

lvds\_fid\_type\_e



# lvds\_dev\_attr\_t

#### 【说明】

LVDS/SubLVDS/HiSPi 设备属性。

#### 【定义】

#### Hi3516A/Hi3518EV200:

```
typedef struct
   img_size_t
                      img_size;
   wdr_mode_e
                      wdr_mode;
   lvds_sync_mode_e
                      sync_mode;
   raw_data_type_e
                      raw_data_type;
   lvds_bit_endian
                      data_endian;
   lvds_bit_endian
                      sync_code_endian;
                       lane_id[LVDS_LANE_NUM];
   short
   unsigned short
                      sync_code[LVDS_LANE_NUM][WDR_VC_NUM][SYNC_CODE_NUM];
}lvds_dev_attr_t;
```

#### Hi3519V100/Hi3516CV300:

```
typedef struct
   img_size_t
                      img_size;
   raw_data_type_e
                     raw_data_type;
   wdr_mode_e
                      wdr_mode;
   lvds_sync_mode_e
                      sync_mode;
   lvds_vsync_type_t vsync_type;
   lvds_fid_type_t
                      fid_type;
   lvds_bit_endian
                      data_endian;
   lvds_bit_endian
                      sync_code_endian;
                      lane_id[LVDS_LANE_NUM];
   short
                      sync_code[LVDS_LANE_NUM][WDR_VC_NUM][SYNC_CODE_NUM];
   unsigned short
} lvds_dev_attr_t;
Hi3519V101:
typedef struct
   raw_data_type_e
                      raw_data_type;
   wdr_mode_e
                      wdr_mode;
```



lvds\_sync\_mode\_e sync\_mode;
lvds\_vsync\_type\_t vsync\_type;
lvds\_fid\_type\_t fid\_type;

lvds\_bit\_endian data\_endian;
lvds\_bit\_endian sync\_code\_endian;
short lane\_id[LVDS\_LANE\_NUM];

unsigned short sync\_code[LVDS\_LANE\_NUM][WDR\_VC\_NUM][SYNC\_CODE\_NUM];
} lvds\_dev\_attr\_t;

#### 【成员】

| 成员名称             | 描述                                                                                                                  |
|------------------|---------------------------------------------------------------------------------------------------------------------|
| img_size         | sensor 输入图像宽高,图像宽度必须是有效 lane 个数的整数 倍。                                                                               |
| wdr_mode         | WDR 模式。                                                                                                             |
| sync_mode        | LVDS 同步模式。                                                                                                          |
| raw_data_type    | 传输的 raw data 比特数。                                                                                                   |
| data_endian      | 数据大小端模式。                                                                                                            |
| sync_code_endian | 同步码大小端模式。                                                                                                           |
| lane_id          | 发送端(sensor)和接收端(MIPI Rx) lane 的对应关系<br>未使用的 lane 设置为-1<br>lane id 的配置方式请参考"Lane id 如何配置"。                           |
| sync_code        | 每个 Virtual Channel 有 4 个同步码,根据同步模式不同,分别表示 SOF/EOF/ SOL/EOL 的同步码或者 invalid SAV/invalid EAV/ valid SAV/valid EAV 的同步码 |
| vsync_type       | vsync 类型,当 wdr_mod 为 DOL 模式并且 sync_mode 为 LVDS_SYNC_MODE_SAV 时,需要配置 vsync 的类型。                                      |
| fid_type         | frame identification 类型,当 wdr_mode 为 DOL 模式,并且 sync_mode 为 LVDS_SYNC_MODE_SAV 时,需要配置。                               |

# 【芯片差异】

| 芯片类型        | raw_data_type             |
|-------------|---------------------------|
| Hi3516A     | 支持 10bit/12bit/14bit      |
| Hi3518EV200 | 支持 8bit/10bit/12bit/14bit |



| 芯片类型        | raw_data_type                   |
|-------------|---------------------------------|
| Hi3519V100  | 支持 8bit/10bit/12bit/14bit/16bit |
| Hi3519V101  | 支持 8bit/10bit/12bit/14bit/16bit |
| Hi3516CV300 | 支持 8bit/10bit/12bit/14bit/16bit |

| 芯片类型        | vsync_type | fid_type |
|-------------|------------|----------|
| Hi3516A     | 不支持        | 不支持      |
| Hi3518EV200 | 不支持        | 不支持      |
| Hi3519V100  | 支持         | 支持       |
| Hi3519V101  | 支持         | 支持       |
| Hi3516CV300 | 支持         | 支持       |

| 芯片类型        | img_size                                  |
|-------------|-------------------------------------------|
| Hi3516A     | 支持                                        |
| Hi3518EV200 | 支持                                        |
| Hi3519V100  | 支持                                        |
| Hi3519V101  | img_size 移入 combo_dev_attr_t 中的 img_rect。 |
| Hi3516CV300 | 支持                                        |

# 【注意事项】

无。

# 【相关数据类型及接口】

- wdr\_mode\_e
- lvds\_sync\_mode\_e
- raw\_data\_type\_e
- lvds\_bit\_endian
- lvds\_vsync\_type\_t
- lvds\_fid\_type\_t
- HI\_MIPI\_SET\_DEV\_ATTR

phy\_cmv\_e

【说明】



# PHY 共模电压模式

# 【定义】

```
typedef enum
{
    PHY_CMV_GE900MV = 0x00,
    PHY_CMV_LT900MV = 0x01,
    PHY_CMV_BUTT
} phy_cmv_e;
```

# 【成员】

| 成员名称            | 描述                 |
|-----------------|--------------------|
| PHY_CMV_GE900MV | PHY 共模电压大于等于 900mv |
| PHY_CMV_LT900MV | PHY 共模电压小于 900 mv  |

# 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |
| Hi3519V100  | 支持   |
| Hi3519V101  | 支持   |
| Hi3516CV300 | 支持   |

# 【注意事项】

无。

【相关数据类型及接口】

无。

# phy\_cmv\_t

#### 【说明】

PHY 共模电压配置信息

# 【定义】

```
typedef struct
{
```



```
COMBO_DEV devno;
phy_cmv_e cmv_mode;
} phy_cmv_t;
```

#### 【成员】

| 成员名称     | 描述          |
|----------|-------------|
| devno    | MIPI Rx 设备号 |
| cmv_mode | PHY 功能电压模式  |

## 【芯片差异】

| 芯片类型        | 是否支持 |
|-------------|------|
| Hi3516A     | 不支持  |
| Hi3518EV200 | 不支持  |
| Hi3519V100  | 支持   |
| Hi3519V101  | 支持   |
| Hi3516CV300 | 支持   |

#### 【注意事项】

无。

#### 【相关数据类型及接口】

- phy cmv e
- HI\_MIPI\_SET\_PHY\_CMVMODE

## combo\_dev\_attr\_t

#### 【说明】

combo 设备属性,由于 MIPI Rx 能够对接 CSI-2、LVDS、HiSPi 等时序,所以将 MIPI Rx 称为 combo 设备。

## 【定义】

#### Hi3516A/Hi3518EV200:

```
typedef struct
{
    input_mode_t input_mode;
    union
    {
```



```
mipi_dev_attr_t
                        mipi_attr;
      lvds_dev_attr_t lvds_attr;
   };
}combo_dev_attr_t;
Hi3519V100:
typedef struct
   COMBO_DEV
                    devno;
   input_mode_t
                       input_mode;
   phy_clk_share_e
                        phy_clk_share;
   union
      mipi_dev_attr_t mipi_attr;
      lvds_dev_attr_t
                        lvds_attr;
   };
} combo_dev_attr_t;
Hi3519V101:
typedef struct
   COMBO_DEV
                       devno;
   input_mode_t
                       input_mode;
   phy_clk_share_e
                       phy_clk_share;
   img_rect_t
                        img_rect;
   union
      mipi_dev_attr_t
                        mipi_attr;
      lvds_dev_attr_t
                        lvds_attr;
   };
} combo_dev_attr_t;
Hi3516CV300:
typedef struct
   COMBO_DEV
                   devno;
   input_mode_t
                        input_mode;
```



```
union
{
    mipi_dev_attr_t mipi_attr;
    lvds_dev_attr_t lvds_attr;
};
} combo_dev_attr_t;
```

#### 【成员】

| 成员名称          | 描述                                                                                    |  |
|---------------|---------------------------------------------------------------------------------------|--|
| input_mode    | 输入接口类型                                                                                |  |
| mipi_attr     | 如果 input_mode 配置为 INPUT_MODE_MIPI,则必须配置 mipi_attr                                     |  |
| lvds_attr     | 如果 input_mode 配置为 INPUT_MODE_SUBLVDS/INPUT_MODE_LVDS/ INPUT_MODE_HISPI,则必须配置lvds_attr |  |
| devno         | MIPI Rx 设备号                                                                           |  |
| phy_clk_share | PHY 共享时钟信息                                                                            |  |
| img_rect      | 图像 crop 区域                                                                            |  |

## 【芯片差异】

| 芯片类型        | devno | phy_clk_share                |
|-------------|-------|------------------------------|
| Hi3516A     | 不支持   | 不支持                          |
| Hi3518EV200 | 不支持   | 不支持                          |
| Hi3519V100  | 支持    | 支持 PHY1 和 PHY2 共享<br>PHY 的时钟 |
| Hi3519V101  | 支持    | 支持 PHY1 和 PHY2 共享<br>PHY 的时钟 |
| Hi3516CV300 | 支持    | 不支持                          |

| 芯片类型        | img_rect                           |
|-------------|------------------------------------|
| Hi3516A     | 不支持                                |
| Hi3518EV200 | 不支持                                |
| Hi3519V100  | 不支持,但可以通过 HI_MIPI_SET_CROP 设置 crop |
| Hi3519V101  | 支持                                 |



| Hi3516CV300 | 不支持 |
|-------------|-----|
|-------------|-----|

## 【注意事项】

无。

【相关数据类型及接口】

无。

# img\_rect\_t

#### 【说明】

Mipi crop 属性。

## 【定义】

```
typedef struct
{
    int x;
    int y;
    unsigned int width;
    unsigned int height;
} img_rect_t;
```

### 【成员】

| 成员名称   | 描述          |  |  |
|--------|-------------|--|--|
| X      | Crop 起始位置 x |  |  |
| у      | Crop 起始位置 y |  |  |
| width  | Crop 宽度     |  |  |
| height | Crop 高度     |  |  |

## 【芯片差异】

| 芯片类型        | CROP 接口 |
|-------------|---------|
| Hi3516A     | 不支持     |
| Hi3518EV200 | 不支持     |
| Hi3519V100  | 支持      |
| Hi3519V101  | 支持      |
| Hi3516CV300 | 不支持     |



#### 【注意事项】

无。

【相关数据类型及接口】

HI\_MIPI\_SET\_CROP

# img\_size\_t

#### 【说明】

图像宽高属性。

#### 【定义】

```
typedef struct
{
   unsigned int width;
   unsigned int height;
} img_size_t;
```

#### 【成员】

| 成员名称   | 描述   |
|--------|------|
| width  | 图像宽度 |
| height | 图像高度 |

#### 【芯片差异】

无。

【注意事项】

无。

【相关数据类型及接口】

HI\_MIPI\_SET\_DEV\_ATTR

# 1.6 PROC 信息

#### 【调试信息】



| Img |      |       |            |      |                   |     |          |   | deEndian  |     |         |            |
|-----|------|-------|------------|------|-------------------|-----|----------|---|-----------|-----|---------|------------|
| 404 |      |       |            |      |                   |     |          |   | 1, 2      | N   | -       | -          |
| 424 | 8    | 2182  | 2          | SAV  |                   | від |          |   | від       |     |         |            |
|     | T. T | TNK T | NFO        |      |                   |     |          |   |           |     |         |            |
|     |      |       | _          |      |                   |     |          |   | a Aligne  |     |         | lLane      |
|     |      | )     |            |      |                   |     |          |   | 0x5252    |     |         |            |
|     | 1    | L     |            |      |                   |     |          |   | 0xa0003   |     |         |            |
|     |      |       |            |      |                   |     |          |   | 0x3e2     |     |         |            |
|     |      |       |            |      |                   |     |          |   |           |     |         |            |
|     | mi   | ipi d | letect     | info | ) <b></b> -       |     |          |   |           |     |         |            |
| Dev | vno  | VC    | width      | hei  | ght.              |     |          |   |           |     |         |            |
|     | 0    | 0     | 4248       | 21   | L82               |     |          |   |           |     |         |            |
|     | 0    | 1     | 0          | (    | 0                 |     |          |   |           |     |         |            |
|     | 0    | 2     | 0          | (    | 0                 |     |          |   |           |     |         |            |
|     | 0    | 3     | 0          | (    | 0                 |     |          |   |           |     |         |            |
|     |      |       |            |      |                   |     |          |   |           |     |         |            |
|     | l    | vds d | letect     | info | )                 |     |          |   |           |     |         |            |
| D   | evn  |       |            |      | neWidtl           | h   |          |   |           |     |         |            |
|     | C    | )     | 0          |      | 531               |     |          |   |           |     |         |            |
|     | C    | )     | 1          |      | 531               |     |          |   |           |     |         |            |
|     | C    | )     | 2          |      | 531               |     |          |   |           |     |         |            |
|     | C    | )     | 3          |      | 531               |     |          |   |           |     |         |            |
|     | C    | )     | 4          |      | 531               |     |          |   |           |     |         |            |
|     | C    | )     | 5          |      | 531               |     |          |   |           |     |         |            |
|     | C    | )     | 6          |      | 531               |     |          |   |           |     |         |            |
|     | C    | )     | 7          |      | 531               |     |          |   |           |     |         |            |
|     |      |       |            |      |                   | _   |          | _ |           |     |         |            |
| D   | evn  |       | R_Fram<br> |      |                   |     | heig     |   |           |     |         |            |
|     | C    |       |            |      | 424               |     |          |   |           |     |         |            |
|     | 0    |       |            |      |                   |     |          | 0 |           |     |         |            |
|     | 0    |       | SEF2       |      |                   |     |          | 0 |           |     |         |            |
|     | U    |       | SEF3       | 3    |                   | 0   |          | 0 |           |     |         |            |
|     | f    | am +i | meou+      | and  | eggane            | inf | <b>\</b> |   |           |     |         |            |
|     |      |       |            |      |                   |     |          |   |           |     |         | clkEscCnt  |
|     |      |       |            |      | ucciic<br>2EscCnt |     |          |   | 210000110 | ası | JUCCIIC | CINIDCCIIC |
|     |      |       | IESCCII    |      |                   | 0   |          | 0 |           | 0   | 0       | 0          |
|     |      | 0     |            |      |                   | 3   |          | J |           | -   | Ü       | J          |
| _   |      | •     |            |      |                   | 0   |          | 0 |           | 0   | 0       | 0          |
|     |      | 0     |            | 0    |                   |     |          | U |           | U   |         | 0          |
|     | 1    | 0     |            | 0    |                   | O   |          | U |           | U   | Ü       | U          |
| 0   | 1    |       |            |      |                   | 0   |          | 0 |           | 0   | 0       | 0          |



----ALING Err info-----

Devno FIFO\_FullErr Lane0Err Lane1Err Lane2Err Lane3Err Lane4Err

Lane5Err Lane6Err Lane7Err Lane8Err Lane9Err Lane10Err Lane11Err

0 0 0 0 0 0 0 0 0 0

0 0 0 0

#### 【调试信息分析】

- MIPI\_Rx 通过 Phy 接收 sensor 的差分数据, Phy Controller 检测到同步头后,将每条 lane 上的数据对齐;
- Pixel Controller 解析同步信息并按照 raw data 的位宽将 lane 上面的数据合并为 Pixel 数据; Output 模式将 Pixel 数据发送给后级模块。
- Phy PhyController PixelController 由 sensor 的 pixel clk 提供时钟,output 模块的时钟为称为随路时钟,与后级模块的工作时钟相同。MIPI\_Rx 的 crop 功能在 Pixel Controller 的末端实现,所以 Crop 后可以降低需要的随路时钟。

#### 图1-3 MIPI 数据流



#### 【参数说明】

| 参数           |          | 描述                                                      |
|--------------|----------|---------------------------------------------------------|
| Combo<br>DEV | Devno    | MIPI 设备号                                                |
| ATTR         | WorkMode | • MIPI 设备工作模式:<br>LVDS/MIPI/CMOS 等模式                    |
|              | DataType | • 数据类型:<br>RAW8 / RAW10/ RAW12/ RAW14/ RAW16<br>bit 等类型 |



| 参数           |                | 描述                                                       |  |  |
|--------------|----------------|----------------------------------------------------------|--|--|
|              | WDRMode        | WDR 模式:                                                  |  |  |
|              |                | • None: 非 WDR 模式                                         |  |  |
|              |                | • 2To1: 2 合 1 WDR                                        |  |  |
|              |                | • 3To1: 3 合 1 WDR                                        |  |  |
|              |                | • 4To1: 4 合 1 WDR                                        |  |  |
|              |                | • DOL2To1: DOL2 合 1WDR                                   |  |  |
|              |                | • DOL3To1: DOL3 合 1WDR                                   |  |  |
|              |                | • DOL4To1: DOL4 合 1WDR                                   |  |  |
|              | LinkId         | 此设备使用了哪几个 Link, 对应 Link ID。<br>一个物理 Link 对应 4 个 lane。    |  |  |
|              | bEnCrop        | Crop 是否使能。N 表示 Crop 被关闭,Y 表示 Crop 使能。                    |  |  |
|              | ImgX           | Crop 图像起始 X                                              |  |  |
|              | ImgY           | Crop 图像起始 Y                                              |  |  |
|              | ImgW           | Crop 图像宽度                                                |  |  |
|              | ImgH           | Crop 图像高度                                                |  |  |
|              | SyncMode       | 同步头模式                                                    |  |  |
|              |                | SOF: 同步方式为 SOF, EOF, SOL, EOL                            |  |  |
|              |                | SAV:同步方式为 invalid SAV, invalid EAV, valid SAV, valid EAV |  |  |
|              | DataEndian     | 数据大小端:                                                   |  |  |
|              |                | ● Big: 大端模式                                              |  |  |
|              |                | • Little: 小端模式                                           |  |  |
|              | SyncCodeEndian | 同步头大小端:                                                  |  |  |
|              |                | ● Big: 大端模式                                              |  |  |
|              |                | • Little: 小端模式                                           |  |  |
| LINK<br>INFO | LinkIdx        | Link ID 序号                                               |  |  |
|              | LaneCount      | 该 Link 中使用了几条 Lane                                       |  |  |
|              | LaneId         | 对应的 Lane Id                                              |  |  |
|              | PhyData        | PHY 接收到的实时数据                                             |  |  |
|              | AlignedData    | 检测到帧同步信号后的实时数据                                           |  |  |
|              | ValidLane      | Link 内部有效 Lane ID。                                       |  |  |



| 参数                                                                                                                         |              | 描述                               |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------|--|--|--|--|--|--|
| mipi                                                                                                                       | Devno        | MIPI_Rx 设备号                      |  |  |  |  |  |  |
| mipi detect info (仅 MIPI 模式下可见) lvds detect info (仅 LVDS/Su bLVDS/Hi SPi 模式下可见)  fsm timeout and escape info (仅 MIPI 模式 见) | VC           | Virtual Channel                  |  |  |  |  |  |  |
| 模式下可                                                                                                                       | width        | MIPI 控制器检测到的图像总宽度                |  |  |  |  |  |  |
| 处)                                                                                                                         | height       | MIPI 控制器检测到的图像总高度                |  |  |  |  |  |  |
|                                                                                                                            | Devno        | MIPI_Rx 设备号                      |  |  |  |  |  |  |
| 11110                                                                                                                      | Lane         | Lane ID 序号                       |  |  |  |  |  |  |
| LVDS/Su                                                                                                                    | LaneWidth    | 对应 lane 检测到的图像宽度                 |  |  |  |  |  |  |
| SPi 模式                                                                                                                     | Devno        | MIPI_Rx 设备号                      |  |  |  |  |  |  |
| 卜 印 见)                                                                                                                     | WDR_Frame    | 表示 WDR 模式下的长短帧,线性模式不显示此列。        |  |  |  |  |  |  |
|                                                                                                                            |              | ● LEF: 长曝光帧                      |  |  |  |  |  |  |
|                                                                                                                            |              | • SEF1: 短曝光帧 1                   |  |  |  |  |  |  |
|                                                                                                                            |              | • SEF2: 短曝光帧 2<br>• SEF3: 短曝光帧 3 |  |  |  |  |  |  |
|                                                                                                                            | width        | LVDS 控制器检测到的图像总宽度                |  |  |  |  |  |  |
|                                                                                                                            | height       | LVDS 控制器检测到的图像总高度                |  |  |  |  |  |  |
| fsm                                                                                                                        | link         | Link ID                          |  |  |  |  |  |  |
|                                                                                                                            | clkTOutCnt   | 时钟 lane 从 LP 切换到 HS 超时           |  |  |  |  |  |  |
| escape                                                                                                                     | d0TOutCnt    | 数据 lane0 从 LP 切换到 HS 超时          |  |  |  |  |  |  |
| (仅 MIPI                                                                                                                    | d1TOutCnt    | 数据 lane1 从 LP 切换到 HS 超时          |  |  |  |  |  |  |
|                                                                                                                            | d2TOutCnt    | 数据 lane2 从 LP 切换到 HS 超时          |  |  |  |  |  |  |
| , <u> </u>                                                                                                                 | d3TOutCnt    | 数据 lane3 从 LP 切换到 HS 超时          |  |  |  |  |  |  |
|                                                                                                                            | clkEscCnt    | 时钟 lane 切换到 escape 模式超时          |  |  |  |  |  |  |
|                                                                                                                            | d0EscCnt     | 数据 lane0 切换到 escape 模式超时         |  |  |  |  |  |  |
|                                                                                                                            | d1EscCnt     | 数据 lane0 切换到 escape 模式超时         |  |  |  |  |  |  |
|                                                                                                                            | d2EscCnt     | 数据 lane0 切换到 escape 模式超时         |  |  |  |  |  |  |
|                                                                                                                            | d3EscCnt     | 数据 lane0 切换到 escape 模式超时         |  |  |  |  |  |  |
| ALING                                                                                                                      | Devno        | MIPI 设备号                         |  |  |  |  |  |  |
| Err info                                                                                                                   | FIFO_FullErr | FIFO 溢出                          |  |  |  |  |  |  |
|                                                                                                                            | Lane0Err     | Lane0 FIFO 溢出                    |  |  |  |  |  |  |



| 参数 |           | 描述             |
|----|-----------|----------------|
|    | Lane1Err  | Lane1 FIFO 溢出  |
|    | Lane2Err  | Lane2 FIFO 溢出  |
|    | Lane3Err  | Lane3 FIFO 溢出  |
|    | Lane4Err  | Lane4 FIFO 溢出  |
|    | Lane5Err  | Lane5 FIFO 溢出  |
|    | Lane6Err  | Lane6 FIFO 溢出  |
|    | Lane7Err  | Lane7 FIFO 溢出  |
|    | Lane8Err  | Lane8 FIFO 溢出  |
|    | Lane9Err  | Lane9 FIFO 溢出  |
|    | Lane10Err | Lane10 FIFO 溢出 |
|    | Lane11Err | Lanell FIFO 溢出 |

# 1.7 FAQ

MIPI 具体规格请参考芯片手册《Hi35xx 专业型 HD IP Camera Soc 用户指南.pdf》和《Features of the Video Interfaces of HiSilicon IP Cameras.pdf》

#### Lane id 如何配置

Lane id 的配置对应 mipi\_dev\_attr\_t 中的 short lane\_id[MIPI\_LANE\_NUM]或者 lvds\_dev\_attr\_t 中的 short lane\_id[LVDS\_LANE\_NUM]。

对接 sensor 时,未使用的 lane 将其对应的 lane\_id 配置为-1。配置 lane\_id 还可以调整数据通道顺序,根据硬件单板与实际 sensor 输出通道的对应关系调整 lane\_id 的配置。

下面以 demo 板 mn34220 为例进行说明,例如 demo 板的  $MIPI_Rx$  引脚与 MN34220 的引脚硬件连接如表 1-3 所示。

表1-3 MN34220 与 MIPI Rx 管脚关系

| MN34220 管脚     | Hi3516A MIPI 管脚 |
|----------------|-----------------|
| SENSOR_SDODA0M | MIPIO_DOM       |
| SENSOR_SDODA0P | MIPIO_DOP       |
| SENSOR_SDODA1M | MIPI0_D1M       |
| SENSOR_SDODA1P | MIPI0_D1P       |



| SENSOR_SDODB0M | MIPI1_D0M |
|----------------|-----------|
| SENSOR_SDODB0P | MIPI1_D0P |
| SENSOR_SDODB1M | MIPI1_D1M |
| SENSOR_SDODB1P | MIPI1_D1P |

引脚上实际传输数据的顺序为 Pixel0, Pixel2, Pixel1, Pixel3, 见图 1-4。

图1-4 MN34220 Output 时序图(2ch 2port 12bit format)

#### 12bit format



由于 sensor 没有输出数据到 MIPI\_Rx 的 MIPI0\_D2M, MIPI0\_D2P, MIPI0\_D3M, MIPI0\_D3P, MIPI1\_D2M, MIPI1\_D2P, MIPI1\_D3M, MIPI1\_D3P, 需要将对于的 lane id 配置为-1,所以所以 lane id 配置如下:

lane\_id = 
$$\{0, 2, -1, -1, 1, 3, -1, -1\}$$

Sync\_code 配置是根据 lane\_id 生效的,如果 lane\_id 为-1,则对应 sync\_code 不会生效。

# 1.7.2 LVDS mode sync code 如何配置

LVDS/SUB\_LVDS 的同步方式有两种模式,参考 lvds\_sync\_mode e:

- LVDS SYNC MODE SOF/LVDS SYNC MODE SOL
- LVDS\_SYNC\_MODE\_SAV

不同 sensor 或者同一 sensor 不同的传输模式都需要配置不同的 sync code。

sync\_code 的定义如下:

 unsigned short sync\_code[LVDS\_LANE\_NUM][WDR\_VC\_NUM][SYNC\_CODE\_NUM]; 需要根据 sensor datasheet 进行配置,如表 1-4 所示。

#### 表1-4 sync\_code 定义

| sync_code 中的元素 | 每一项的含义          |
|----------------|-----------------|
| LVDS_LANE_NUM  | 对应 lvds 硬件物理通道。 |



| WDR_VC_NUM    | WDR 通道数,如 2 合 1WDR 对应 2 个 WDR 通道,最多为4 个。                 |
|---------------|----------------------------------------------------------|
| SYNC_CODE_NUM | 每条 lane 的 Sync_code 由 4 个码字组成,在不同的同步模式下对应的含义不同,请参考表 1-2。 |

#### □ 说明

每一 SOF/EOF/SOL/EOL 的 sync code 前三个为固定码字: 0xFFFF 0x0000 0x0000

## Hi3516A/Hi3518EV200 同步码配置举例

Sync code 配置的原则:

- 同一个 Link 内乱序时,无论硬件以何种顺序与 Sensor 连接,Sync code 都按照正常顺序配置。
- 两个 Link 之间乱序时,仍然遵循上述准则,即在同一 Link 内保持正常顺序配置。Panasonic 的 Sensor 普遍存在两个 Link 之间乱序,其他厂家暂不涉及。

#### 举例:

举例 1: 同一 Link 内乱序
 MN34220 工作在 1 channel 4port(4 lane) 12bit 模式时, datasheet 中关于 sync code 的描述,如图 1-5 所示。

#### 图1-5 同步码

| ch   | port  | Name |      | Code (1 | 2bit×4) | $\overline{Z}$ | ch       | port  | Name |      | (2bit×4 | $\overline{}$ |      |
|------|-------|------|------|---------|---------|----------------|----------|-------|------|------|---------|---------------|------|
|      |       | SOF  | FFFh | 000h    | 000h    | 002h           |          | Port2 | SOF  | FFFh | 000h    | 000h          | 012h |
|      | Dest  | SOL  | FFFh | 000h    | 000h    | 000h           | <b>\</b> |       | SOL  | FFFh | 000h    | 000h          | 010h |
|      | Port0 | EOL  | FFFh | 000h    | 000h    | 001h           | ch1      |       | EOL  | FFFh | 000h    | 000h          | 011h |
| -1.1 |       | EOF  | FFFh | 000h    | 000h    | 003h           |          |       | EOF  | FFFh | 000h    | 000h          | 013h |
| ch1  | Port1 | SOF  | FFFh | 000h    | 000h    | 006h           |          | Port3 | SOF  | FFFh | 000h    | 000h          | 016h |
|      |       | SOL  | FFFh | 000h    | 000h    | 004h           |          |       | SOL  | FFFh | 000h    | 000h          | 014h |
|      |       | EOL  | FFFh | 000h    | 000h    | 005h           |          |       | EOL  | FFFh | 000h    | 000h          | 015h |
|      |       | EOF  | FFFh | 000h    | 000h    | 007h           |          |       | EOF  | FFFh | 000h    | 000h          | 017b |

各通道像素格式,如图 1-6 所示。

#### 图1-6 像素格式图





所以相当于正常的顺序应该为 SDODA0、SDODB0、SDODA1、SDODB1, 只有前面 4 个通道的 sync code 配置有效。应该按照这个顺序在 mipi 接口中配置 Sync code。则 sync\_code 配置为:

```
.sync_code = {
                \{\{0x002, 0x003, 0x000, 0x001\}, //PHY0_lane0\}
                \{0x202, 0x203, 0x200, 0x201\},\
                {0x102, 0x103, 0x100, 0x101},
                {0x302, 0x303, 0x300, 0x301}},
                \{\{0x012, 0x013, 0x010, 0x011\}, //PHY0\_lane1\}
                {0x212, 0x213, 0x210, 0x211},
                {0x112, 0x113, 0x110, 0x111},
                {0x312, 0x313, 0x310, 0x311}},
                \{\{0x006, 0x007, 0x004, 0x005\}, //PHY0\_lane2\}
                \{0x206, 0x207, 0x204, 0x205\},\
                \{0x106, 0x107, 0x104, 0x105\},\
                \{0x306, 0x307, 0x304, 0x305\}\},
                \{\{0x016, 0x017, 0x014, 0x015\}, //PHY0\_lane3\}
                \{0x216, 0x217, 0x214, 0x215\},\
                \{0x116, 0x117, 0x114, 0x115\},\
                \{0x316, 0x317, 0x314, 0x315\}\},
                \{\{0x00a, 0x00b, 0x008, 0x009\}, //PHY1_lane0\}
                {0x20a, 0x20b, 0x208, 0x209},
                {0x10a, 0x10b, 0x108, 0x109},
                \{0x30a, 0x30b, 0x308, 0x309\}\},
                \{\{0x00a, 0x00b, 0x008, 0x009\}, //PHY1\_lane1\}
                {0x20a, 0x20b, 0x208, 0x209},
                \{0x10a, 0x10b, 0x108, 0x109\},\
                \{0x30a, 0x30b, 0x308, 0x309\}\},
                {{0x01a, 0x01b, 0x018, 0x019}, //PHY1_lane2
                \{0x21a, 0x21b, 0x218, 0x219\},\
                {0x11a, 0x11b, 0x118, 0x119},
                \{0x31a, 0x31b, 0x318, 0x319\}\},
                \{\{0x01a, 0x01b, 0x018, 0x019\}, //PHY1\_lane3\}
                \{0x21a, 0x21b, 0x218, 0x219\},\
                {0x11a, 0x11b, 0x118, 0x119},
                \{0x31a, 0x31b, 0x318, 0x319\}\}
             }
```



● 举例 2: 两个 Link 之间乱序

MN34220 工作在 2 channel 2port(4 lane) 12bit 模式时,datasheet 中关于 sync code 的描述,如图 1-7 同步码。

#### 图1-7 同步码

| ch  | port   | Name |      | Code (1 | (2bit×4 | $\rangle$ | ch  | port  | Name |      | Code (1 | $\overline{}$ |      |
|-----|--------|------|------|---------|---------|-----------|-----|-------|------|------|---------|---------------|------|
|     |        | SOF  | FFFh | 000h    | 000h    | 002h      |     | Port0 | SOF  | FFFh | 000h    | 000h          | 012h |
| 1   | Dourt0 | SOL  | FFFh | 000h    | 000h    | 000h      | ch2 |       | SOL  | FFFh | 000h    | 000h          | 010h |
| 1   | Port0  | EOL  | FFFh | 000h    | 000h    | 001h      |     |       | EOL  | FFFh | 000h    | 000h          | 011h |
| ch1 |        | EOF  | FFFh | 000h    | 000h    | 003h      |     |       | EOF  | FFFh | 000h    | 000h          | 013h |
| cni |        | SOF  | FFFh | 000h    | 000h    | 006h      |     | Port1 | SOF  | FFFh | 000h    | 000h          | 016h |
|     | Port1  | SOL  | FFFh | 000h    | 000h    | 004h      |     |       | SOL  | FFFh | 000h    | 000h          | 014h |
|     |        | EOL  | FFFh | 000h    | 000h    | 005h      |     |       | EOL  | FFFh | 000h    | 000h          | 015h |
|     |        | EOF  | FFFh | 000h    | 000h    | 007h      |     |       | EOF  | FFFh | 000h    | 000h          | 017h |

各通道像素格式,如图 1-8 所示。

#### 图1-8 像素格式图



由于在两个 Link 之间线序有交叉,但是根据上述原则,只在同一 Link 内部考虑 Sync code 的配置。

Link0 的通道 0,通道 1 和 Link1 的通道 0,通道 1 配置的 sync code 有效。所以最终的的 sync code 配置为:



```
\{\{0x00a, 0x00b, 0x008, 0x009\}, //PHY0_lane3\}
{0x20a, 0x20b, 0x208, 0x209},
\{0x10a, 0x10b, 0x108, 0x109\},\
\{0x30a, 0x30b, 0x308, 0x309\}\},
\{\{0x012, 0x013, 0x010, 0x011\}, //PHY1\_lane0\}
{0x212, 0x213, 0x210, 0x211},
{0x112, 0x113, 0x110, 0x111},
\{0x312, 0x313, 0x310, 0x311\}\},
\{\{0x016, 0x017, 0x014, 0x015\}, //PHY1_lane1\}
{0x216, 0x217, 0x214, 0x215},
\{0x116, 0x117, 0x114, 0x115\},\
\{0x316, 0x317, 0x314, 0x315\}\},
\{\{0x01a, 0x01b, 0x018, 0x019\}, //PHY1\_lane2
\{0x21a, 0x21b, 0x218, 0x219\},\
{0x11a, 0x11b, 0x118, 0x119},
\{0x31a, 0x31b, 0x318, 0x319\}\},
\{\{0x01a, 0x01b, 0x018, 0x019\}, //PHY1\_lane3
\{0x21a, 0x21b, 0x218, 0x219\},\
{0x11a, 0x11b, 0x118, 0x119},
{0x31a, 0x31b, 0x318, 0x319}}
```

# Hi3519V100/Hi3519V101/Hi3516CV300 同步码配置举例

}

Sync code 配置的原则:

根据实际使用多少个 lane,配置 sync\_code 中前几个 lane 的同步码。如果 lane 乱序,Sync code 按照正常顺序配置。

举例:

MN34220 工作在 2 channel 2port(4 lane) 12bit 模式时,datasheet 中关于 sync code 的描述,如图 1-9 所示。

图1-9 同步码

| ch  | port  | Name |      | Code (12bit×4) |      |      | ch  | port  | Name | Code (12bit×4) |      |      | $\rangle$ |
|-----|-------|------|------|----------------|------|------|-----|-------|------|----------------|------|------|-----------|
|     |       | SOF  | FFFh | 000h           | 000h | 002h |     | Port0 | SOF  | FFFh           | 000h | 000h | 012h      |
|     | Port0 | SOL  | FFFh | 000h           | 000h | 000h | 1   |       | SOL  | FFFh           | 000h | 000h | 010h      |
|     | rono  | EOL  | FFFh | 000h           | 000h | 001h | ch2 |       | EOL  | FFFh           | 000h | 000h | 011h      |
| ch1 |       | EOF  | FFFh | 000h           | 000h | 003h |     |       | EOF  | FFFh           | 000h | 000h | 013h      |
| cni |       | SOF  | FFFh | 000h           | 000h | 006h |     | Port1 | SOF  | FFFh           | 000h | 000h | 016h      |
|     | Dest  | SOL  | FFFh | 000h           | 000h | 004h |     |       | SOL  | FFFh           | 000h | 000h | 014h      |
|     | Port1 | EOL  | FFFh | 000h           | 000h | 005h |     |       | EOL  | FFFh           | 000h | 000h | 015h      |
|     |       | EOF  | FFFh | 000h           | 000h | 007h |     |       | EOF  | FFFh           | 000h | 000h | 017h      |



各通道像素格式,如图 1-10 所示。

#### 图1-10 像素格式图



```
\{0x202, 0x203, 0x200, 0x201\}, // VC1
    {0x102, 0x103, 0x100, 0x101}, // VC2
    {0x302, 0x303, 0x300, 0x301} // VC3
},
    // lane1 (mn34220 chn2 port0)
\{0x012, 0x013, 0x010, 0x011\},\
    {0x212, 0x213, 0x210, 0x211},
    {0x112, 0x113, 0x110, 0x111},
    {0x312, 0x313, 0x310, 0x311}
},
    // lane2 (mn34220 chn1 port1)
\{0x006, 0x007, 0x004, 0x005\},\
    \{0x206, 0x207, 0x204, 0x205\},\
    {0x106, 0x107, 0x104, 0x105},
    {0x306, 0x307, 0x304, 0x305}
},
    // lane3 (mn34220 chn2 port1)
\{0x016, 0x017, 0x014, 0x015\},\
    {0x216, 0x217, 0x214, 0x215},
    \{0x116, 0x117, 0x114, 0x115\},\
    {0x316, 0x317, 0x314, 0x315}
}
```

}



# 1.7.3 MIPI 频率说明

### MIPI lane 频率与 VI 频率关系

使用 MIPI 多个 lanes 进行数据传输, mipi lane 的传输频率与 VI 处理频率如何对应, 每一 lane 可传输的最高速率如何计算?

- MIPI\_Rx 使用多 lane 接收数据,会转成内部时序,送给 VI 模块进行处理,多 lane 传输的数据总量不变,有这样的计算公式:
  - VI\_Freq \* Pix\_Width = Lane\_Num \* MIPI\_Freq
- 其中,VI\_Freq为VI的工作时钟,Pix\_Width为像素位宽,Lane\_Num为传输lane个数,MIPIFreq为一个lane能接收的最大频率。
- 下面以 VI 工作频率为 250M, MIPI 数据为 RAW 12, 4Lane 传输为例进行说明: MIPI\_Freq = (250 \* 12) / 4 = 750 即每个 lane 最高频率为 750MHz

## 1.7.4 Sensor 复位

- sensor reset/unreset 操作是在 mipi 驱动中实现的, mipi 驱动中的复位顺序如下:
  - sensor reset
  - mipi core reset
  - config mipi attr
  - mipi core unreset
  - sensor unreset
- 芯片有一个 pin 脚专门用于 sensor 复位(SENSOR\_RSTN), 建议客户默认使用。
- 如果需要修改 sensor reset pin,需要注意 mipi 驱动做适配修改,根据实际使用的管脚,在 mipi 驱动。
- mipi\_reset\_sensor/mipi\_unreset\_sensor 或者 mipi\_drv\_reset\_sensor/mipi drv unreset sensor 函数中进行适配。
- 如果 sensor 支持 standby 模式,不希望进行 reset sensor 操作,可以将 mipi\_reset\_sensor/mipi\_unreset\_sensor 或者 mipi\_drv\_reset\_sensor/mipi\_drv\_unreset\_sensor 操作去掉, sensor reset 改成 enable sensor standby 模式, sensor unreset 改成 disable standby 模式。